class Solution {//leetcode44——通配符匹配
public:
    bool isMatch(string s, string p) {
        int m=s.size(),n=p.size();
        vector<vector<bool>> dp(m+1,vector<bool>(n+1,false));
        s=" "+s;
        p=" "+p;
        dp[0][0]=true;
        for(int j=1;j<n+1;j++)
        {
            if(p[j]=='*') dp[0][j]=true;
            else break;
        }
        for(int j=1;j<n+1;j++){
            for(int i=1;i<m+1;i++){
                if(s[i]==p[j]||p[j]=='?') dp[i][j]=dp[i-1][j-1];
                if(p[j]=='*') dp[i][j]=dp[i-1][j-1]||dp[i-1][j]||dp[i][j-1];
            }
        }
        return dp[m][n];
    }
};